

**FIG.2** 



## 

## ASSIGNMENT

after an input signal CE is asserted by filling in empty spaces in the following circuit source code (Verilog-HDL). INSTRUCTION: Design a circuit for lighting ON/OFF LED by manipulating a push button (Note that LED is OFF before the input signal CE is asserted.)

5

```
// signal register for keeping the current push button signal with respect to r_pclk synchronization
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         ^{\prime\prime} signal register for keeping the previous push button signal with respect clock synchronization
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   // 20 bit counter end signal (for generation of chattering prevention clock)
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      // 20 bit counter register (for generation of chattering prevention clock)
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              // 3 bit width register indicative of the current circuit status
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        // signal line indicative of an idle status
// signal line indicative of a LED light OFF status
// signal line indicative of a LED light ON status
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       // chattering prevented push button input signal
                                                                                                                                                                        //\, light ON LED (negative logic) output signal
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            //\, chattering prevention clock signal register
                                                                                // chip enable input signal
// push button input signal (negative logic)
                           // 33MHz clock input signal
// reset input signal (negative logic)
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           // Declaration part of inner signal lines and registers
                                                                                                                                                                                                                                                              // Declaration part of input and output port signals
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           s_state_idle;
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   s_cnt_end;
                                                                                                                                                                                                                                                                                                                                                                              push_n;
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         r_pre_push_n
                                                                                                                                                                                                                                                                                                                        rst_n;
                                                                                                                                                                                                                                                                                                                                                       ce:
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            r_push_n;
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            reg[[2]]r_state:
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            r_pclk;
                                                                                                                                                                                                                                                                                                                                                                                                                                     led_n:
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      reg [ 1 ]r_cnt;
module light_led(
                                                                                                                    ,u_hsnd
                                                            rst_n,
                                                                                                                                                                           led_n
                                                                                           ce,
                                                                                                                                                                                                                                                                                                                                                                                                                                        output
                                                                                                                                                                                                                                                                                               input
                                                                                                                                                                                                                                                                                                                        input
                                                                                                                                                                                                                                                                                                                                                    input
                                                                                                                                                                                                                                                                                                                                                                               input
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       Wire
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              Wire
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    reg
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           reg
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 reg
```

s\_state\_led\_off; s\_state\_led\_on;

Wire ₩ire

## FIG.5

```
3 : // chip enable input signal wait status = 4 : // LED light OFF status
                                                                                                                                                                                   /st If the counter is "0xF_FFF", output "1", otherwise, output "0".
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      /* If reset becomes active, input "0" as an initial value. */
if ( rst_n == 1'b0 ) begin
                                                                        5 // LED light ON status
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           /* Count up in a status other than the idle status. */
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      ) begin
                                                                                                                                                                                                                                                                                            /st Only if the push button is pushed, assign ^{''}1 ^{''}
                                                                                                                                                                                                                (Logical operations for all bits are used.) */
                                                                                                                                                                                                                                       6 | r_cnt;
                                                                                                                                                            // Combinatorial circuit description
// Register statuses as parameters
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 = 12 ;
                                                                            | ED_0N = |
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                // Order circuit description
                                                                                                                                                                                                                                                                                                                                                                                                   s_state_led_off
                                                                                                                                                                                                                                                                                                                                                                                                                               s_state_led_on
                                                   LED_OFF
                                                                                                                                                                                                                                                                                                                                                                          s_state_idle
                                                                                                                                                                                                                                           assign s_cnt_end = [
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           end else begin
                                                                                                                                                                                                                                                                                                                         assign s_pushed
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    assign led_n
                            parameter
                                                       parameter
                                                                                parameter
                                                                                                                                                                                                                                                                                                                                                                            assign
                                                                                                                                                                                                                                                                                                                                                                                                      assign
                                                                                                                                                                                                                                                                                                                                                                                                                                  assign
```



FIG.8



FIG.9



## FIG.10

| QUESTION |                                 |                                |                | REQUIRED             | REQUIRED SKILLS (WEIGHTED POINTS) | TED POINTS)                          |                                |
|----------|---------------------------------|--------------------------------|----------------|----------------------|-----------------------------------|--------------------------------------|--------------------------------|
| NUMBER   | CORRECT ANSWER                  | SPECIFICATION<br>COMPREHENSION | HDL<br>GRAMMAR | SIGNAL<br>DEFINITION | PARAMETER<br>DEFINITION           | COMBINATIONAL<br>CIRCUIT DESCRIPTION | SEQUENTIAL CIRCUIT DESCRIPTION |
| 1        | 19:0                            | 1                              | 1              | 1                    |                                   |                                      |                                |
| 2        | 2:0                             | 1                              | 1              | 1                    |                                   |                                      |                                |
| 3        | 3' 5001                         | 1                              | 1              |                      | 2                                 |                                      |                                |
| 4        | 3' 5010                         | 1                              | 1              |                      | 2                                 |                                      |                                |
| 5        | 3, 100                          | 1                              | 1              |                      | 2                                 |                                      |                                |
| 9        | &                               | 2                              | 1              |                      |                                   | 2                                    |                                |
| 7        | r_push_n                        | 2                              | 1              |                      |                                   | •                                    |                                |
| 8        | r_pre_push_n                    | 2                              | ı              |                      |                                   | -                                    |                                |
| 6        | r_state[0]                      | 1                              | ı              |                      | -                                 | -                                    |                                |
| 10       | r_state[1]                      | 1                              | 1              |                      | 1                                 | -                                    |                                |
| 11       | r_state[2]                      | 1                              | l              |                      | 1                                 | 1                                    |                                |
| 12       | s_state_led_on                  | 3                              | ı              |                      |                                   | 2                                    |                                |
| 13       | posedge clk or negedge rst_n    | 1                              | 1              |                      |                                   |                                      | 1                              |
| 14       | 20' h0                          |                                | 1              |                      |                                   |                                      |                                |
| 15       | s_state_idle                    | 2                              | . 1            |                      |                                   |                                      | 2                              |
| 16       | r_cnt <= r_cnt + 20' h1         | 3                              | 1              |                      |                                   |                                      | 2                              |
| 17       | posedge clk or negedge rst_n    | 1                              | 1              |                      |                                   |                                      | 1                              |
| 18       | s_cnt_end                       | 2                              | 1              |                      |                                   |                                      | 2                              |
| 19       | _r_pclk                         | 3                              | 1              |                      |                                   |                                      | 2                              |
| 20       | posedge r pclk or negedge rst_n | 1                              | 1              |                      |                                   |                                      |                                |
| 21       | s_state_idle                    | 2                              | 1              |                      |                                   |                                      | 2                              |
| 22       | push_n                          | 3                              | ļ              |                      |                                   |                                      | 2                              |
| 23       | posedge clk or negedge rst_n    | 1                              | -              |                      |                                   |                                      | 1                              |
| 24       | s_state_idle                    | 2                              | _              |                      |                                   |                                      | 2                              |
| 25       | r_push_n                        | 3                              | 1              |                      |                                   | 0                                    | 2                              |
| 26       | posedge clk or negedge rst_n    | 1                              | 1              |                      |                                   |                                      | 1                              |
| 27       | case ( r_state )                | 1                              | 1              |                      |                                   |                                      | 2                              |
| 28       | СӨ                              | 2                              | 1              |                      |                                   |                                      | 2                              |
| 29       | s_pushed                        | 2                              | 1              |                      |                                   |                                      | 2                              |
| 30       | s_pushed                        | 2                              | 1              |                      |                                   |                                      | 2                              |
| 31       | r_state <= IDLE                 | 3                              | 1              |                      |                                   |                                      | 2                              |
| 32       | endcase                         | 1                              |                |                      |                                   |                                      | 1                              |
| 33       | endmodule                       | -                              | -              |                      |                                   |                                      | 1                              |

FIG.11A

| 19 | SPECIFICATION HDL SIGNAL PARAMETER CIRCUIT COMPREHENSION GRAMMAR DEFINITION DESCRIPTION DESCRIPTION DESCRIPTION | IMUM         55         33         2         9         6         34 | SING 45 28 1 6 6 27 |
|----|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|---------------------|
|    |                                                                                                                 | MAXIMUM                                                             | PASSING<br>SCORE    |

FIG.11B

| 79                                      | REQUIRED SKILLS | DL SIGNAL PARAMETER COMBINATIONAL SEQUENTIAL CIRCUIT | KAIMIMAR DEFINITION DESCRIPTION DESCRIPTION | 7 9 5 29 |
|-----------------------------------------|-----------------|------------------------------------------------------|---------------------------------------------|----------|
|                                         | REQUIRED SKILLS |                                                      |                                             | 2        |
| * · · · · · · · · · · · · · · · · · · · |                 | HDL                                                  | GRAMMAR                                     | 27       |
|                                         |                 | SPECIFICATION                                        | COMPREHENSION                               | 42       |
|                                         |                 |                                                      |                                             | SCORE    |



**FIG.13** 





**FIG.15** 





FIG.17

| INTERVALS | NOR OPERATION<br>RESULTS | COINCIDENCE<br>DEGREES<br>BETWEEN<br>WAVEFORM START<br>AND END POINTS | NUMBER OF<br>WAVEFORM<br>CHANGES |
|-----------|--------------------------|-----------------------------------------------------------------------|----------------------------------|
|           | က                        | 1                                                                     |                                  |
|           | 2                        | ı                                                                     | I                                |
| 176       | I                        | -                                                                     | က                                |
|           | I                        | -                                                                     | 0                                |
|           | l                        | 1                                                                     | က                                |

|           |                                | . E                                 | REQUIRED SKILLS             | S   |            |
|-----------|--------------------------------|-------------------------------------|-----------------------------|-----|------------|
| INTERVALS | SPECIFICATION<br>COMPREHENSION | IFICATION RESET REHENSION OPERATION | PUSH<br>BUTTON<br>OPERATION | LED | CHATTERING |
| 0,0       | 1                              | -                                   |                             | -   |            |
| 3,4,5     | 9*                             |                                     | L*                          | £*  | . 9<br>*   |

FIG. 19A

|    |                 | <del></del>                            | · · · · · · · · · · · · · · · · · · · | 1                |
|----|-----------------|----------------------------------------|---------------------------------------|------------------|
| 91 |                 | LED CHATTERING OPERATION COMPREHENSION | 4                                     | 2                |
|    | S               | LED<br>OPERATION                       | 2                                     | 7                |
|    | REQUIRED SKILLS | PUSH<br>BUTTON<br>OPERATION            | 1                                     | 1                |
|    | RE              | RESET                                  | 1                                     | 1                |
|    |                 | SPECIFICATION                          | ಬ                                     | 3                |
| '  |                 |                                        | MAXIMUM<br>SCORE                      | PASSING<br>SCORE |

FIG. 19B

| SPECIFICATION RESET COMPREHENSION OPERATION O | 92 | REQUIRED SKILLS | BUTTON COMPREHENSION COMPREHENSION | 1 2 2 |
|-----------------------------------------------|----|-----------------|------------------------------------|-------|
| i I I                                         |    |                 |                                    | 8     |







